<template>
    <div>
        <el-button type="warning" size="small" id="audit" @click="AuditComment_show=true"><i class="el-icon-finished"></i>审批</el-button>
        <el-button type="success" size="small" id="printBtn" v-print="printObj"><i class="el-icon-printer"></i>打印</el-button>

        <form class="wrapper" id="wrapperApplyPurchaseTable">
            <div class="header">
                <img src="/image/logo.jpg" /><label>固基行远，协晨悟通</label>
            </div>
            <h2 class="Title">固远晨通科技发展有限公司项目实施计划表</h2>
            <table class="report_data" id="LAY-EXPORT-TEST" rules=all>
                <tr>
                    <td class="td_Title">项目名称</td>
                    <td class="td_Content">{{dataProject.ProjectName}}</td>
                    <td class="td_Title">所属行业</td> 
                    <td class="td_Content">{{dataProject.Industry}}</td>
                    <td class="td_Title">项目编号</td>
                    <td class="td_Content">{{dataProject.ProjectNumber}}</td>
                </tr>
                <tr>
                    <td class="td_Title">开始时间</td>
                    <td class="td_Content">{{ fmtDate(dataProject.CreateDate) }}</td>
                    <td class="td_Title">结束时间</td>
                    <td class="td_Content">{{ fmtDate(dataProject.FinishDate) }}</td>
                    <td class="td_Title">项目负责人</td>
                    <td class="td_Content">{{ GetNameByUserId(dataProject.HeadUserId) }}</td>
                </tr>
                <tr class="tr_two">
                    <td class="td_Title">项目类型</td>
                    <td class="td_Content" colspan="6">
                        <el-checkbox-group v-model="ProjectTypeLis" size="medium" disabled>
                            <el-checkbox :label="1" border>施工生产</el-checkbox>
                            <el-checkbox :label="2" border>产品生产</el-checkbox>
                            <el-checkbox :label="4" border>产品研发</el-checkbox>
                            <el-checkbox :label="8" border>技术服务</el-checkbox>
                            <el-checkbox :label="16" border>其它</el-checkbox>
                        </el-checkbox-group>
                    </td>
                </tr>
                <tr class="tr_one"><td class="td_Title" colspan="6">（工序/专业/任务）分解</td></tr>
            </table>
            <table class="report_data" rules=all>
                <tr>
                    <th class="td_Title">序号</th>
                    <th class="td_Title">项目工序</th>
                    <th class="td_Title">工序内容</th>
                    <th class="td_Title">工程总量</th>
                    <th class="td_Title">单价</th>
                    <th class="td_Title">计划开始日期</th>
                    <th class="td_Title">计划结束日期</th>
                    <th class="td_Title">工天</th>
                    <th class="td_Title">计划人员</th>
                    <th class="td_Title">计划材料</th>
                    <th class="td_Title">计划机械</th>
                </tr>
                <tr v-for="(d,i) in dataProjectWorkPlans">
                    <th>{{ (i+1) }}</th>
                    <th>{{ d.ConstructionProcedure }}</th>
                    <th>{{ d.ConstructionContents }}</th>
                    <th>{{ d.TotalQuantity + d.Unit }}</th>
                    <th>{{ d.Price }}</th>
                    <th>{{ fmtDate(d.PlanStartDate) }}</th>
                    <th>{{ fmtDate(d.PlanEndDate) }}</th>
                    <th>{{ Datedifference(d.PlanStartDate,d.PlanEndDate) }}</th>
                    <th>{{ d.Planner }}</th>
                    <th>{{ d.PlanningMaterials }}</th>
                    <th>{{ d.PlanningMachinery }}</th>
                </tr>
                <tr class="tr_one" id="AddHtml">
                    <td class="td_Title">备注</td>
                    <td class="td_Content" colspan="10">{{ dataProjectWorkPlans.Remark }}</td>
                </tr>
                <tr class="tr_one">
                    <td class="td_Title" colspan="2">项目负责人签批</td>
                    <td colspan="9">
                        <p class="audit" id="audit1">{{ GetNameByUserId(dataProjectWorkPlans.AuditUserId1) }}</p>
                        <p class="time" id="time1">{{ fmtDate(dataProjectWorkPlans.AuditTime1) }}</p>
                    </td>
                </tr>
                <tr class="tr_one">
                    <td class="td_Title" colspan="2">计划经营部签批</td>
                    <td colspan="9">
                        <p class="audit" id="audit2">{{ GetNameByUserId(dataProjectWorkPlans.AuditUserId2) }}</p>
                        <p class="time" id="time2">{{ fmtDate(dataProjectWorkPlans.AuditTime1) }}</p>
                    </td>
                </tr>
                <tr class="tr_one">
                    <td class="td_Title" colspan="2">总经理/董事长签批</td>
                    <td colspan="9">
                        <p class="audit" id="audit3">{{ GetNameByUserId(dataProjectWorkPlans.AuditUserId3) }}</p>
                        <p class="time" id="time3">{{ fmtDate(dataProjectWorkPlans.AuditTime1) }}</p>
                    </td>
                </tr>
            </table>
            <div class="author"><span>固远晨通科技发展有限公司制</span></div>
            <div id="Footer">
                <div><span style="margin-right: 100px;">固远晨通科技发展有限公司</span><span>网址：<a>www.guyuanct.com</a></span></div>
                <div><span>地址：成都西区大道199号成都模具工业园C1栋</span></div>
            </div>
        </form>

        <el-dialog v-if="AuditComment_show" :modal="false"  :visible.sync="AuditComment_show" width="40%" title="审批"  :before-close="onClose">
            <AuditComment ref="AuditCommentRef" :approval-receipt="Approval_event" :approval="Approval"></AuditComment>
        </el-dialog>
    </div>
</template>

<script>
    import AuditComment from "../../AuditComment";
    import * as publicjs from "../../../../public/Scriput/Public";

    export default {
        name: "ProjectimplementationscheduleTable",
        components:{
            AuditComment
        },
        props:{
            project:{
                type:Object,
                required:true,
            }
        },
        data(){
            return{
                printObj: {
                    id: "wrapperApplyPurchaseTable",  //打印标签的id
                    popTitle: '',  //文件标题
                },
                // 审批弹框
                AuditComment_show:false,
                // 审批弹窗返回数据
                Approval: {
                    State: 1,
                    Comment: '',
                },
                ProjectTypeLis:[],
                dataProject:{},
                dataProjectWorkPlans:[],
                GetCompanyAllUsers:[],
            }
        },
        watch:{
            project:function () {
                this.GetData()
            }
        },
        mounted() {
            let _this = this
            this.$nextTick(()=>{
                _this.GetData()
            })
        },
        methods:{
            //天数计算
            Datedifference(CreateDate,FinishDate){
                return publicjs.datedifference(CreateDate,FinishDate)
            },
            //数据转换
            fmtDate(val){
                if (val!=null&&val!=''){
                    return val.split(' ')[0]
                }else{
                    return ''
                }
            },
            // 关闭审批结果组件
            async onClose(done) {
                await done();
                this.$refs["AuditCommentRef"].FormClose_event();
            },
            //审批
            Approval_event(){
                this.$http.post('Project1/AuditProjectWorkPlanReport',{ ProjectId:this.project.Id }).then(res=>{
                    if (res.data.IsSuccess){
                        this.$message.success(res.data.Msg)
                        this.AuditComment_show=false
                        this.GetData()
                    }else{
                        this.$message.warning(res.data.Msg)
                    }
                })
                this.$refs["AuditCommentRef"].FormClose_event();
            },
            //构造详细的申购单内物资信息
            GetData(){
                this.$http.post('Project1/GetProjectWorkPlanReport',{ ProjectId: this.project.Id }).then(res=>{
                    console.log(res.data)
                    this.dataProject = res.data.dataProject;
                    this.dataProjectWorkPlans = res.data.dataProjectWorkPlans;
                    this.ProjectTypeLis = this.dataProject.ProjectType.toString().split(',').map(x=> parseInt(x))
                })
            },
            //根据userid数组获取userName,主要用于公司人员
            GetNameByUserId(UserId){
                for (let i=0;i<this.$store.state.AllUsers.length;i++){
                    if (this.$store.state.AllUsers[i].Id == parseInt(UserId)){
                        return this.$store.state.AllUsers[i].UserName
                    }
                }
            },
        }
    }
</script>

<style scoped>
    #audit {
        position: absolute;
        right: 11%;
        top: 80px;
        z-index: 9999;
    }
    #printBtn {
        position: absolute;
        right: 11%;
        top: 115px;
        z-index: 9999;
    }
    /*外包装样式*/
    .wrapper {
        width: 80%;
        height: 100%;
        margin: auto;
    }
    /*页眉样式*/
    .header {
        font-weight: bold;
        font-size: 20px;
        font-family: cursive;
        width: 80%;
        margin: auto;
        border-bottom: 2px solid black;
        padding: 10px 0px;
        position: relative;
    }

    .header img {
        width: 200px;
        height: 55px;
    }

    .header label {
        position: absolute;
        bottom: 10px;
        right: 70px;
    }
    /*标题样式*/
    h2 {
        width: 80%;
        text-align: center;
        font-size: 25px;
        font-weight: bold;
        margin: auto;
        padding: 10px 0;
    }
    /*标题样式*/
    h4 {
        width: 80%;
        text-align: center;
        font-weight: bold;
        margin: auto;
        padding: 10px 0;
    }
    /*数据表格样式*/
    .report_data {
        width: 100%;
        text-align: center;
        border: 1px solid black;
        font-size: 14px;
        word-break: break-all;
    }

    .report_data tr {
        height: 40px;
    }

    .report_data th {
        font-weight: 100;
    }
    .baseInfo .worderWrapper {
        display: inline-block;
        width: 200px;
    }
    .report_audit .tdCenter {
        text-align: center;
    }

    .report_audit tr {
        height: 70px;
    }

    .report_audit tr p {
        padding: 3px;
    }

    .report_audit td {
        padding: 0 10px;
    }

    .report_audit td:first-child {
        width: 150px;
    }

    .report_audit .tr_center {
        text-align: center;
    }

    tr p.audit {
        font: italic bold 20px/30px arial,sans-serif;
        text-align: right;
        /*padding-right: 110px;*/
    }

    tr p.audit span {
        display: inline-block;
        width: 100px;
        font: bold 17px/30px arial,sans-serif;
    }

    tr p.gray {
        color: gray;
    }

    tr p.audit span.red {
        color: red;
    }

    tr p.audit span.blue {
        color: blue;
    }
    .author {
        width: 80%;
        margin: auto;
        margin-top: 5px;
        font-weight: bold;
        text-align: right;
    }
    /*页脚样式*/
    #Footer {
        width: 80%;
        margin: auto;
        border-top: 2px solid black;
        margin-top: 60px;
        font-weight: bold;
    }
    #Footer div {
        padding-top: 5px;
        padding-bottom: 10px;
    }
    #search select {
        text-align: left;
    }
    /*折叠面板样式修改*/
    .layui-collapse .layui-colla-title {
        margin: 0;
        width: 100%;
        text-align: left;
    }
    /*报表管理下统计报表的样式*/
    #EchartData .pie {
        height: 500px;
    }

    #EchartData .pieData {
        float: left;
        width: 50%;
        height: 500px;
    }

    #EchartData .bar {
        width: 100%;
        height: 500px;
    }

    .report_data .tr_one {
        height: 50px;
    }

    .report_data .tr_two {
        height: 100px;
    }

    .report_data .td_Title {
        font-weight: bold;
    }

    .td_left {
        text-align: left;
        padding-left: 20px;
    }

    .td_Content {
        padding: 5Px 5px;
    }

    .report_data .layui-disabled, .report_data .layui-disabled:hover {
        color: black !important;
    }

    .report_data .layui-form-radio > i:hover, .report_data .layui-form-radioed > i {
        color: #5FB878 !important;
    }
</style>
